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Abstract. In a previous work Baillot and Terui introduced Dual light affine logic (DLAL) 
as a variant of Light linear logic suitable for guaranteeing complexity properties on lambda 
calculus terms: all typable terms can be evaluated in polynomial time by beta reduction 
and all Ptime functions can be represented. In the present work we address the problem of 
typing lambda-terms in second-order DLAL. For that we give a procedure which, starting 
with a term typed in system F, determines whether it is typable in DLAL and outputs 
a concrete typing if there exists any. We show that our procedure can be run in time 
polynomial in the size of the original Church typed system F term. 



Several works have studied programming languages with intrinsic computational com- 
plexity properties. This line of research, Implicit computational complexity (ICC), is moti- 
vated both by the perspective of automated complexity analysis, and by foundational goals, 
in particular to give natural characterisations of complexity classes, like Ptime or Pspace. 
Different calculi have been used for this purpose coming from primitive recursion, lambda 
calculus, rewriting systems (e.g. [BC92, MM00, LM93]). . . A convenient way to see these 
systems is in general to describe them as a subset of programs of a larger language satisfying 
certain criteria: for instance primitive recursive programs satisfying safe/ramified recursion 
conditions, rewriting systems admitting a termination ordering and quasi interpretation, 
etc. . . 

Inference. To use such ICC systems for programming purpose it is natural to wish 
to automatize the verification of the criterion. This way the user could stick to a simple 
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programming language and the compiler would check whether the program satisfies the 
criterion, in which case a complexity property would be guaranteed. 

In general this decision procedure involves finding a certain witness, like a type, a 
proof or a termination ordering. Depending on the system this witness might be useful to 
provide more precise information, like an actual bound on the running time, or a suitable 
strategy to evaluate the program. It might be used as a certificate guaranteeing a particular 
quantitative property of the program. 

Light linear logic. In the present work we consider the approach of Light linear logic 
(LLL) ([Gir98j), a variant of Linear logic which characterises polynomial time computation, 
within the proofs-as-programs correspondence. It includes higher-order and polymorphism, 
and can be extended to a naive set theory ( }Ter04j ). in which the provably total functions 
correspond to the class of polynomial time functions. 

The original formulation of LLL by Girard was quite complicated, but a first simplifi- 
cation was given by Asperti with Light affine logic (LAV) ([AR02]). Both systems have two 
modalities (one more than Linear logic) to control duplication. There is a forgetful map to 
system F terms (polymorphic types) obtained by erasing some information (modalities) in 
types; if an LAL typed term t is mapped to an F-typed term M we also say that t is a 
decoration of M. 

So an LAL program can be understood as a system F program, together with a typing 
guarantee that it can be evaluated in polynomial time once that program is written and 
evaluated in the right syntax (see below). As system F is a reference system for the study 
of polymorphically typed functional languages and has been extensively studied, this seems 
to offer a solid basis to LAL. 

However LAL itself is still difficult to handle and following the previous idea for the 
application of ICC methods, we would prefer to use plain lambda calculus as a front-end 
language, without having to worry about the handling of modalities, and instead to delegate 
the LAL typing part to a type inference engine. The study of this approach was started in 
|Bai02]. For it to be fully manageable however several conditions should be fulfilled: 

(1) a suitable way to execute the lambda-terms with the expected complexity bound, 

(2) an efficient type inference, 

(3) a typed language which is expressive enough so that a reasonable range of programs is 
accepted. 

The language LAL presents some drawback for the first point, because the LAL typed 
terms need to be evaluated with a specific graph syntax, proof-nets, in order to satisfy the 
polynomial bound, and plain beta reduction can lead to exponential blow-up. 

In a previous work ([BT04]) we addressed this issue by defining a subsystem of LAL, 
called Dual light affine logic (DLAL). It is defined with both linear and non-linear function 
types. It is complete for Ptime just as LAL and its main advantage is that it is also Ptime 
sound w.r.t. beta reduction: a DLAL term admits a bound on the length of all its beta 
reduction sequences. Hence DLAL stands as a reasonable substitute for plain LAL for 
typing issues. 

Concerning point 2, as type inference for system F is undecidable ([Wel99]) we do not 
try to give a fully-fledged type inference algorithm from untyped terms. Instead, to separate 
the polymorphic part issue from the proper DLAL part one, we assume the initial program 
to be already typed in F. Either the system F typing work is left to the user, or one could 
use a partial algorithm for system F typing for this preliminary phase. 
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So the contribution of the present work is to define an efficient algorithm to decide if 
a system F term can be decorated in a DLAL typed term. This was actually one of the 
original motivations for defining DLAL. We show here that decoration can be performed in 
polynomial time. This is obtained by taking advantage of intuitions coming from proof-nets, 
but it is presented in a standard form with a first phase consisting in generating constraints 
expressing typability and a second phase for constraints solving. One difficulty is that the 
initial presentation of the constraints involves disjunctions of linear constraints, for which 
there is no obvious Ptime bound. Hence we provide a specific resolution strategy. 

The complete algorithm is already implemented in ML, in a way that follows closely 
the specification given in the article. It is modular and usable with any linear constraints 
solver. The code is commented, and available for public download (Section [7|). With this 
program one might thus write terms in system F and verify if they are Ptime and obtain a 
time upper bound. It should in particular be useful to study further properties of DLAL 
and to experiment with reasonable size programs. 

The point 3 stressed previously about expressivity of the system remains an issue which 
should be explored further. Indeed the DLAL typing discipline will in particular rule out 
some nested iterations which might in fact be harmless for Ptime complexity. This is related 
to the line of work on the study of intensional aspects of Implicit computational complexity 
([MMQQiDI]). 

However it might be possible to consider some combination of DLAL with other systems 
which could allow for more flexibility, and we think a better understanding of DLAL and 
in particular of its type inference, is a necessary step in that direction. 

Related work. Inference problems have been studied for several ICC systems (e.g. 
[Ama05| . |HJ 03]). Elementary linear logic (EAL, [Gir98, DJ03]) in particular is another 
variant of Linear logic which characterises Kalmar elementary time and has applications to 
optimal reduction. Type inference for propositional EAL (without second-order) has been 
studied in |CM01| . [CBZR03] . [CDLBdB,05] and |BT05| w hich gives a po lynomial time pro- 
cedure. Type inference for LAL was also investigated, in [Bai02, Bai04j. To our knowledge 
the present algorithm is however the first one for dealing with polymorphic types in an 
EAL-related system, and also the first one to infer light types in polynomial time. 

This article is an extended version of the paper [ABT06]. Its main novelties are the 
following ones: 

• it is self-contained and complete proofs are provided for the theorems; 

• a new section has been added discussing the problem of type inference with data-type 
domain specification (Section [6]); 

• the section on the implementation of the algorithm and examples of type inference (Sec- 
tion [7|) has been developed, with in particular more examples like the predecessor and 
polynomials. 

Acknowledgements. The authors wish to thank Laurent Regnier for useful discus- 
sions related to the topic of this paper. 

2. From system F to DLAL 
The language Cf of system F types is given by: 

T,U ::= a | T -> U j Va.T . 
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We assume that a countable set of term variables x , y , z , . . . is given for each type 
T. The terms of system F are built as follows (here we write M T to indicate that the term 
M has type T): 

x T {\x T .M u ) T - u {(M T ~* U )N T ) U {Ka.M u f a - u m Wa - u )T) u ™ , 

with the proviso that when building a term Aa.M, a does not occur free in the types 
of free term variables of M (the eigenvariable condition). The set of free variables of M is 
denoted FV(M). 

It is well known that there is no sensible resource bound (i.e. time/space) on the ex- 
ecution of system F terms in general. On the other hand, we are practically interested in 
those terms which can be executed in polynomial time. However the class V of such terms 
is neither recursively enumerable nor co-recursively enumerable. This can be verified for 
instance in the following way, by reduction of the problem of solvability of Diophantine 
equations. For each Diophantine equation P{x) = 0, build a lambda term Mp such that, 
when a binary word w is given, Mp{w) returns e if P{x) = has an integer solution n with 
— \w\ < n < \w\, and returns a word of length 2^' otherwise. Then Mp € V iff P{x) = 
has an integer solution. There is also a complementary reduction, establishing our claim. 
Actually a stronger result is shown in [BMM07] : the class V is Sg-complete. 

So we are naturally led to the study of sufficiently large subclasses of V . The system 
DLAL gives such a class in a purely type-theoretic way. 

The language Cdlal of DLAL types is given by: 

A, B ::= a \ A -o B \ A =^ B \ §A \ Ma. A . 

We note §M = A and § fc+1 A = §§ fc A The erasure map (.) from Cdlal to Cf is defined 
by: 

(§A)~ = A~, (A~o By = (A=> By = A- -» B~, 

and (.)~ commutes with the other connectives. We say A £ Cdlal is a decoration of T € Cf 
if A~ = T. 

A declaration is a pair of the form x T : B with B~ = T. It is often written as x : B 
for simplicity. A judgement is of the form T; A h M : A, where M is a system F term, 
A £ Cdlal and T and A are disjoint sets of declarations. The intuition is that the (free) 
variables in T are duplicable (non-linear), while the ones in A are not (they are linear). 
When A consists of x\ : Ai,...,x n : A n , §A denotes x\ : §A±, . . . ,x n : §A n . The type 
assignment rules are given on Figure [H Here, we assume that the substitution M[N/x] 
used in (§ e) is capture-free. Namely, no free type variable a occurring in is bound in 
M[N/x\. We write T; A \~ dlal M : A if the judgement T; A h M : A is derivable. 
Examples of concrete programs typable in DLAL are given in Section [71 
Recall that binary words, in {0, 1}*, can be given in system F the type: 

Wf = Va.(a — s- a) — > (a — > a) — > (a — > a) . 

A corresponding type in DLAL, containing the same terms, is given by: 

Wdlal = Va.(a -oa)4(a-oa)=> §(a — o a) . 

The depth d{A) of a DLAL type A is defined by: 

d(a) = 0, d(Va.B) = d(B), 

d(A B) = max(d(A),d(B)), d(§A) = d(A) + l, 

d(A => B) = max{d{A) + 1, d{B)). 
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(Id) 

; x A : A h x A : A 

T;x A ~ : A, Ah M : B T 1 ;A 1 \-M:A^>B T 2 ;A 2 hN:A 

r ; A h Xx A ~.M : A -o B ri,r 2 ; Ai, A 2 P (M)N : S 

r ; AhAx A ".M: r, z : C; A h (M)iV : B e ) (*) 

Ti; Ai h M : A Xl : A,x 2 : A,T; A\- M : B 

ri,r 2 ;Ai,A 2 l-M: A ( Weak ) x : A, V; A h Af [z/ajj , x/x 2 ] : B (Cntr) 

; r,AhM:4 . ri;AihJV:§A r 2 ; x : §A, A 2 h M : g 



r ; §A h M : §A vs ; ri,r 2 ;Ai,A 2 h M[JV/»] : 5 

T;A\-M:A r; A h M : Ma. A 

( v i) (**) r-Ak^R-. Zr^i ( v e ) 



r ; A h Aa.M : Va.A vv ' r ; A h (M)B~ : A[B/a 

(*) z : C can be absent. 



a does not occur free in T, A. 



Figure 1: Typing system F terms in DLAL 

A type A is said to be IIi if it does not contain a negative occurrence of V; like for instance 
Wdlal- 

The fundamental properties of DLAL are the following [BT04] : 
Theorem 2.1. 

(1) For every function f : {0, 1}* — > {0, 1}* in DTIME[n fc ], there exists a closed term M 
of type Wdlal —° § Wdlal with d = 0(logk) representing f. 

(2) Let M be a closed term of system F that has a II i type A in DLAL. Then M can be 
normalized in 0(\M\ 2d ) steps by (3 -reduction, where d = d{A) and \M\ is the structural 
size of M . Moreover, the size of any intermediary term occurring in normalization is 
also bounded by 0(\M\ 2d ). □ 

Although DLAL does not capture all Ptime algorithms V, the result 1 guarantees that 
DLAL is at least expressive enough to represent all Ptime functions. In fact, DLAL is as 
expressive as LAL even at the level of algorithms, because there exists a generic translation 
from LAL to DLAL given by: 

(\A)° = Va.((A° =$> a) — ° a), (.)° commutes with other connectives than !. 

See the full version of [BT04] (forthcoming) for details. 

The result 2 on the other hand implies that if we ignore the embedded types occurring 
in M, the normal form of M can be computed in polynomial time (by ordinary ^ -reduction; 
that is the difference from LAL). 

Now, let m Wf ~* Wf be a system F typed term and suppose that we know that it has a 
DLAL type Wdlal —° § d Wdlal for some d > 0. Then, by the consequence of the above 
theorem, we know that the term M is Ptime. In fact, given a binary word w € {0,1}*, 
consider its Church coding w of type Wdlal- Then we have that (M)w has type § d Wdlal, 
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and can thus be evaluated in 0(\w\ 2d+1 ) steps. Thus by assigning a DLAL type to a given 
system F term, one can statically verify a polynomial time bound for its execution. 

In order to use DLAL for resource verification of system F terms, we address the 
following problem: 

Problem 2.2 (DLAL typing). Given a closed term M T of system F, determine if there is 
a decoration A of T such that \~dlal M : A. 

(Here the closedness assumption is only for readability.) 

In the sequel, we show that there is a polynomial time algorithm for solving the DLAL 
typing problem. 



3. Localization of DLAL type inference 

To solve the DLAL typing problem, the main obstacle is that the typing rules of DLAL 
are not syntax-directed. In particular, the rule (§ i) does not correspond to any constructs 
of system F terms, and the rule (§ e) involves term substitution. These features make local 
reasoning on types impossible. 

To overcome the difficulty, we introduce (following [AR02J) an intermediary syntax 
which is more informative than system F terms, but not more informative than DLAL 
derivations themselves (in !3.ip . In particular, it has explicit constructs for (§ i). In addition, 
we replace the global typing rules of DLAL (which involve substitution) with some local 
typing rules and a set of conditions (in 13.31 and 13. 4p . We then show that our Local typing 
rules and conditions exactly characterise system F terms typable in DLAL (in I3.5P . 

3.1. Pseudo-terms. We begin with introducing an intermediary syntax, which consists of 
DLAL-k types and pseudo-terms. 

First we decompose A B into \A — ° B. The language Cdlal* of DLAL-k types is 
given by: 

A ::= a | D —o A \ Va.A | §A , 
D ::= A\\A. 

There is a natural map (.)* from Cdlal to Cdlal* such that (A =^ B)* = \A* — o B* 
and commutes with the other operations. The erasure map (.)~ from Cdlal* to Cf can be 
defined as before. A DLAL-k type is called a bang type if it is of the form \A, and otherwise 
called a linear type. In the sequel, A, B, C stand for linear types, and D for either bang or 
linear types. 

We assume there is a countable set of term variables x D ,y D , z D , . . . for each D € 
Cdlal*- The pseudo-terms are defined by the following grammar: 

t, u ::= x D | \x D .t | (t)u \ Aa.t \ (t)A | §i | §i , 

where A is a linear type and D is an arbitrary one. The idea is that § corresponds to the main 
door of a §-box (or a !-box) in proof-nets ([Gir87, AR02]) while § corresponds to auxiliary 
doors. But note that there is no information in the pseudo-terms to link occurrences of § 
and § corresponding to the same box, nor distinction between §-boxes and !-boxes. 
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There is a natural erasure map from pseudo-terms to system F terms, which we will 
also denote by (.)~ , consisting in removing all occurrences of §,§, replacing x D with x D 
and (t)A with {t)A~ . When t~ = M, t is called a decoration of M. 

Let i be a pseudo-term and u be a subterm of t. We say that u is a door- extreme 
subterm of t if the following holds: if u is of the form u = §u' or u = §u' then §it and §« are 
not subterms of t. 

As an example consider t = {x §§y). Its door-extreme subterms are {t, x, §§y, y}, and 
§y is a subterm of t but not a door-extreme subterm. 

For our purpose, it is sufficient to consider the class of regular pseudo-terms, given by: 

it ::= x D | Xx D .t | (t)t | Aai | (i)^4 , 
t ::= § m u, 

where m is an arbitrary value in Z and § m i denotes § • • • §t (m times) if m > 0, and §•••§£ 
(— m times) if m < 0. 

In other words, a pseudo-term is regular if and only if it does not contain any subterm 
of the form SSu or §Sm. 



3.2. Pseudo-terms and proof- nets. In this section we illustrate the links between pseudo- 
terms and proof-nets. It is independent of the sequel and can be skipped without problem. 

The translation (.)* from DLAL to LAL gives a mapping on derivations; therefore a 
DLAL type derivation corresponds to an LAL proof and thus to a proof-net (|AR02]). To 
facilitate the reading we will use here a 'syntax-tree like' representation for intuitionistic 
LAL proof-nets. 

As an example consider the following term: 

M = (A/.(/)((/) x))((Xh.h) g) . 

It can be given the typing x : §a h M : §a, with the derivation of Fig. [2j The corresponding 
(intuitionistic) proof-net is given on Fig. SJ For readers more familiar with the classical 
representation of proof-nets (in the style of e.g. [AR02] ) , the corresponding representation 
is given on Fig. [3j 

; fl '■ — o a h /2 : a — o a ; x : a h x : a 

; fi '■ Oi — o ot, x : ct \- (fa) x : ct ; /i : a — o oc h /i : a — ° a 

Th ■■ Kh ■ Kx : ah (TO gj : a 

f 1 :0,f 2 :(3;x:§ a \- (/i) ((/ 2 ) x) : §a ; ; g h ft : g 

/ : ft^ : §a h (/) ((/) a) : §a jHUiM^ j 3 ■ g H g ■ g 

;x : §a h A/.(/) ((/) x) : g g- §a ; fl : h (Afe.fe) g : 

g:f3;x:§ a h (A/.(/) ((/) x))((Aft./l) g) : §a 

where /3 = a —° a. 
Figure 2: Example: DLAL derivation for M. 

The pseudo-term corresponding to the previous derivation is: 

t = (A/.§(§/)((§/) Ix)M(Xh-h) §<?)• 

It is represented graphically on Fig. to § and § correspond respectively opening and 
closing doors. 
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Figure 3: Classical Proof-Net corresponding to the example. 




Figure 4: Example of Proof-Net. 



In a proof-net, a box can be thought of as an opening door connected to a certain 
number (possibly none) of closing doors. If in the proof-net of Fig. U] we disconnect opening 
doors from closing doors we get the graph of Fig. [5l corresponding to the pseudo-term. 

Our method for type inference relies on a procedure for deciding if a pseudo-term 
comes from a DLAL derivation. This essentially corresponds to deciding if a pseudo-term 
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Figure 5: Example: graph corresponding to pseudo-term. 



corresponds to a proof-net, that is to say in particular deciding whether opening and closing 
doors can be matched in such a way to yield a correct distribution of boxes. 

3.3. Local typing condition. We now describe a way to assign types to pseudo-terms 
in a locally compatible way. A delicate point in DLAL is that it is sometimes natural to 
associate two types to one variable x. For instance, we have x : A; \~dlal % '■ §A in DLAL, 
and this can be read as x : \A h x : §^4 in terms of DLAL* types. We thus distinguish 
between the input types, which are inherent to variables, and the output types, which are 
inductively assigned to all pseudo-terms. The condition (i) below is concerned with the 
output types. In the sequel, D° denotes §^4 if D is of the form \A, and otherwise denotes 
D itself. 

A pseudo-term t satisfies the Local typing condition if the following holds: 
(i) one can inductively assign a linear type to each subterm of t in the following way (here 
the notation t : A indicates that t has the output type A): 

t : B t:D~oB u : A D° = A 

x D : D° Xx D .t :D^>B ' ' ' ' (t)u : B 

t : A § A t : A t : Va.A 

§t:§A §t:A Aa.t : Va.A (t)B : A[B/a] 
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(ii) when a variable x occurs more than once in t, it is typed as x , 

(iii) t satisfies the eigenvariable condition. Namely, for any subterm of the form Aa.u and 
any free term variable x D in u, a does not occur free in D. 

We also say that t is locally typed. 

The Local typing rules are syntax-directed, and assign a unique type to each pseudo- 
term whenever possible. Notice that there is a type mismatch between D and A in the 
application rule when D is a bang type. This mismatch will be settled by the Bang condition 
below. 

3.4. Boxing conditions. It is clear that local typability is not a sufficient condition for 
typability in DLAL, as it does not ensure that doors §,§ are well placed so that boxes 
can be built around them. Moreover, it does not distinguish §- and !- boxes. We therefore 
impose additional conditions on locally typed pseudo-terms. 

We consider words over the language £ = {§,§}* and < the prefix ordering. If t is a 
pseudo-term and u is an occurrence of subterm in i, let doors(t, , u) be the word inductively 
defined as follows. If t = u, let doors(i, u) = e. Otherwise: 

doors(§i,-u) = § :: (doors(t, u)), 

doors(§£,-u) = § :: (doors(t, u)), 

doors(Ay D .£i, u) = doors(Aa.ti, u) = doors((ii)A, u) = doors(ii, u), 

doors((ti)t2, u) = doors(tj, u), where ti is the subterm containing u. 

That is to say, doors(t, u) collects the modal symbols §, § occurring on the path from the 
root to the node u in the term tree of t. We define a map s : C — > Z by: 

s(e) = 0, 

«(§::/) = 1 + 8(1), 

s(§ :: Z) = -l + s(l). 

A word I G C is weakly well-bracketed if Ml' < /, s(l') > 0, and is well-bracketed if this 
condition holds and moreover s(l) = 0: think of § and § resp. as opening and closing 
brackets. 

Bracketing condition. Let t be a pseudo-term. We say that t satisfies the Bracketing 
condition if: 

(i) for any occurrence of free variable x in t, doors(£, x) is well-bracketed; 

(ii) for any occurrence of an abstraction subterm Xx.v of t: 
(ii.a) doors(t, Xx.v) is weakly well-bracketed, and 

(ii.b) for any occurrence of x in v, doors(v, x) is well-bracketed. 

This condition is sufficient to rule out the canonical morphisms for dereliction and 
digging, which are not valid in DLAL (nor in EAL): 

\x§ A .§x : §A -o A, Ax §A .§x : §A -o §§,4 . 

Since doors(§x,x) = § and doors(§x,x) = §, they do not satisfy the Bracketing condition 
(ii.b). 

Remark 3.1. On the graph representation of pseudo-terms, conditions (i), (ii.a) and (ii.b) 
can be visualised as conditions of bracketing holding on certain paths of the graph: for 
instance condition (ii.b) means that any (top-down) path from a Xx binder to an edge 
corresponding to an occurrence of x is well-bracketed (considering the opening and closing 
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doors). For instance the pseudo-term graph of Fig. [5] satisfies these conditions; we show on 
the Figure two paths 71, 72 that have to be well-bracketed according to (ii.b). 

Bang condition. Let t be a locally typed pseudo-term. A subterm u is called a bang 
subterm of t if it occurs as (t')u in t for some t' : \A — o B. We say that t satisfies the Bang 
condition if for any bang subterm u of t, 

(i) u contains at most one occurrence of free variable x G , and it has a bang type \C. 

(ii) for any subterm v of u such that v/a and v ^ x, s(doors(u, v)) > 1. 

This condition is sufficient to rule out the canonical morphisms for monoidalness 
\A®\B—o\(A B) and §^4— o\A which are not valid in LAL (the following terms and types 
are slightly more complicated since Cdlal* does not explicitly contain a type of the form 
A^\B): 

In the first pseudo-term, the bang subterm §((§x)§^) contains more than one free variable. 
In the second pseudo-term, the bang subterm §(§x) has a free variable x with a linear type. 
Hence they both violate the Bang condition (i). 

Remark 3.2. The intuition behind the Bang condition might be easier to understand on 
the graph representation of pseudo-terms. The idea is that in a proof-net, the argument 
of a non-linear application should be enclosed in a box, with at most one free variable, as 
in the Example of Fig. HI This is enforced on the pseudo-term by Bang conditions (i) and 
(ii). Condition (ii) indeed forces the root of the argument of the application to start with 
an opening door, and this opening door can only be matched by a closing door on the edge 
corresponding to the free variable x. 

A-Scope condition. The previous conditions, Bracketing and Bang, would be enough 
to deal with boxes in the propositional fragment of DLAL. For handling second-order 
quantification though, we need a further condition to take into account the sequentiality 
enforced by the quantifiers. For instance consider the following two formulas (the second 
one is known as Barcan's formula) : 

(1) §Vq.A -o Va.§A , (2) Va.§A -o §Va.,4 . 

Assuming a occurs free in A, formula (1) is provable while (2) is not. Observe that we can 
build the following pseudo-terms which are locally typed and have respectively type (1) and 
(2): 

t x = Ax§ Va - A Aa.§((§x)a) , t 2 = Ax Va - §A .§Aa.§((x)a) . 

Both pseudo-terms satisfy the previous conditions, but t 2 does not correspond to a DLAL 
derivation. 

Let u be a locally typed pseudo-term. We say that u depends on a if the type of u 
contains a free variable a. We say that a locally typed pseudo-term t satisfies the A-scope 
condition if: for any subterm Aa.u of t and for any subterm v of u that depends on a, 
doors(n, v) is weakly well-bracketed. 

Coming back to our example: t% satisfies the A-scope condition, but t 2 does not, because 
(x)a depends on a and nevertheless doors(§((x)a), (x)a) = § is not weakly well-bracketed. 

We now give a reformulation of the Bang condition (ii), which will be useful later: 
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Lemma 3.3. Assume that t is a locally typed regular pseudo-term that satisfies the Brack- 
eting condition and that u is a bang subterm oft that satisfies the Bang condition (i). If u 
has a free variable call it x. Then the Bang condition (ii) holds for u iff: 

for any door-extreme subterm v of u such that i, s(doors(ii, v)) > 1; and 

s(doors(u, x)) = 0, if u has a free variable x. 

Proof. As for the 'only-if direction, it suffices to show that s(doors(u, x)) = whenever 
u has a free variable x. By the Bracketing condition, there is a subterm w of t such that 
doors(u>,a;) is well-bracketed (w is of the form Xx.v, or w = t if x is free in t). Therefore 
s(doors(w,u)) > and s(doors(w,x)) = 0, so s(doors(u, x)) < 0. Let u' be the smallest 
subterm of u strictly containing x. We have s(doors(it, u')) > land— 1 < s(doors(n', x)) < 1, 
so s(doors(u, x)) = 0. 

To show the 'if direction, let v be a subterm of u such that v ^ u. If u has a free 
variable x we also assume that v ^ x. If v is a door-extreme subterm then s(doors(n, v)) > 1. 
Otherwise there are two door-extreme subterms vi, t>2 of u such that: 

• v\ C v C V2, where C denotes the subterm relation, 

• v\ is an immediate distinct door-extreme subterm of 
Because of regularity, we have: 

either s(doors(n, ^2)) > s(doors(u, v)) > s(doors(u, v\)), 

or s(doors(u, ^2)) < s(doors(u, v)) < s(doors(u, v\)). 

Moreover we know that s(doors(u, ^2)) > 1 and s(doors(n, v\)) > (because if v\ = x then 
«s(doors(n, v\)) = 0, and otherwise s(doors(n, v 1)) > 1). Therefore we have s(doors(n, v)) > 
1. □ 



3.5. Correctness of the conditions. So far we have introduced four conditions on pseudo- 
terms: Local typing, Bracketing, Bang and A-scope. Let us call a regular pseudo-term sat- 
isfying these conditions well- structured. It turns out that the well-structured pseudo-terms 
exactly correspond to the DLAL typing derivations. 

Lemma 3.4. Let Mq be a system F term. If 

xx : Ax, . . . , x m : A m ; y x : B\, . . . , y n : B n \~dlal M : C, 

then there is a decoration t of Mq with type C* and with free variables x'^ 1 , . . . , x'm m , 
y^ 1 , . . . , y^" which is well-structured. 

Proof. One can build a (possibly non-regular) decoration Mq of Mq by induction on the 
derivation. Depending on the last typing rule used (see Figure [H), takes one of the 
following forms: 

(Id) x A * 

(-0 i) \x A \M + (-0 e) {M + )N + 

(=► i) Ax !A \M+ (=> e) (M+)§AT+[§z !C 7z] 

(Weak) M + (Cntr) M+[x/x 1 ,x/x 2 ] 

(Vi) ' Aq.M+ (Ve) (M+)B* 

(§i) §M + [lxf /*i,hp /Vj] (§e) M+[N+/x], 

where M + in (§ i) has free variables x Al , . . . , x^ m , yf 1 , . . . , y^"- 
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It is easy to verify that Mq admits Local typing with the output type C* and has the 

free variables xf 1 Xm m , yf 1 , . . . , y% 71 ■ 

Moreover, one can show by induction on the derivation that satisfies the Bracketing, 
Bang and A-scope conditions. Let us just remark: 

• The rules (— o i) and (=> i) introduce new abstraction terms \x A * .M + and \x' A .M + , re- 
spectively. The Bracketing condition (h.b) for them follows from the Bracketing condition 
(i) for M+. 

• The rule (=> e) introduces a new bang term §N + \§z' c * /z]. It satisfies the Bang condition 
(i) because N contains at most one linear variable z. The condition (ii) holds because N+ 
satisfies the Bracketing condition, and thus we have doors(iV + , u) > for any subterm 
occurrence u. 

Observe also that the Bracketing condition is maintained because the § added before 
iV + and the § added before the variable z match each other, so z remains well-bracketed, 
and condition (i) is preserved; since we add a § on TV, condition (ii.a) is maintained as 
well; and as bounded variables of N are left unmodified, (ii.b) is obviously still verified. 

We also have to make sure that the substitution of §z for z does not violate the A-scope 
condition. It follows from the eigenvariable condition for N, which ensures that z does 
not depend on any bound type variable. 

• The rule (Cntr) conforms to the Local typing condition (ii). 

• The rule (V i) introduces a new type abstraction Aa.M + . The A-scope condition for it 
follows from the Bracketing condition for M + . 

• The rule (§ i) clearly preserves the Bracketing condition. It is also clear that the sub- 
stitution involved does not cause violation of the Bang condition (as Xj's and y^s have 
linear types in M + , and thus do not appear in any bang term), and the A-scope condi- 
tion (as Xj's and y^s do not depend on any bound type variable due to the eigenvariable 
condition) . 

• The rule (§ e) involves substitution. The term M + [N + /x] satisfies the A-scope condition 
since substitution is capture-free, and thus no free type variable in N + becomes bound 
in M+[N+/x]. 

Finally, the required regular pseudo-term t is obtained from Mq by applying the fol- 
lowing rewrite rules as many times as possible: 

§§« — > u, §§u — ► u. 

It is clear that all the conditions are preserved by these rewritings. □ 

To show the converse direction, the following Lemma plays a crucial role: 

Lemma 3.5 (Boxing). If§t : §A is a well-structured pseudo-term, then there exist pseudo- 
terms v : A, u\ : §B±, u n : §B n , unique (up to renaming of v's free variables) such 
that: 

(1) FV(v) = {xf 1 , . . . ,x^ n } and each X{ occurs exactly once in v, 

(2) §i = §v\§ui/xi, . . . , §u n /x n ] (substitution is assumed to be capture-free), 

(3) v, m, . . . , u n are well-structured. 

Proof. Given §t, assign an index to each occurrence of § and § in §t to distinguish occurrences 
(we assume that the outermost § has index 0). By traversing from the root of the syntactic 
tree, one can find closing brackets §i,...,§ n that match the opening bracket §o in §oi. 
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Replace each %m : Bi with a fresh and distinct free variable xf l (1 <i < n), and let §t> be 
the resulting pseudo-term. This way one can obtain v, ui, . . . , u n , such that condition (2) 
holds. 

Strictly speaking, it has to be checked that the substitution does not cause capture of 
type or term variables. Let us consider the case of type variables: suppose that ui contains 
a subterm s that depends on a bound variable a of §u. Then §ot contains a subterm of 
the form Aa.f'^j^ifsJ/xi]. However, doors(t/', s) with v" = f'[§jUj[s]/xj] cannot be weakly 
well-bracketed because §j has to match the outermost opening bracket §o- This contradicts 
the A-scope condition for §ot. Hence the case of type variable capture is solved. A similar 
argument using the Bracketing condition shows that the substitutions do no cause term 
variable capture either. 

As to condition (1), we claim that v does not contain a free variable other than 
xi, . . . ,x n . If there is any, say y, then it is also a free variable of t, thus the Bracket- 
ing condition for §ot implies that doors(§ot, y) is well-bracketed, and thus there is a closing 
bracket that matches §o in the path from §oi to y. That means that y belongs to one of u\, 
. . . , u n , not to v. A contradiction. 

Let us now check condition (3). As to the Bracketing condition (i) for v, let li = 
doors(§ot, §jMj) for each 1 < i < n. Then we have s(l) > 1 for all e / I < k and 
s(k) = 1, and the same is true of the list doors(§o«, Xi). Therefore, doors(t>,Xj) is well- 
bracketed for each 1 < i < n. (ii.a) and (ii.b) are easy. As for Uj (1 < i < n), notice 
that s(doors(§o£, Ui)) = 0. This means that for any subterm occurrence v! of Ui, we have 
s (doors (ui, u')) = s(doors(§ot, u')). Therefore, the Bracketing condition for Ui reduces to 
that for §oi. 

The A-scope condition for v, u±, . . . , u n easily reduces to that for §oi. 

As to the Local typing condition, the only nontrivial point to check is whether v satisfies 
the eigenvariable condition. Suppose that Xi depends on a variable a which is bound in 
v. Then §ot contains a subterm of the form Aa.t/[§jUj/xj] and Ui depends on a. However, 
doors(V', Ui) with v" = v'\§iUi/xi] cannot be weakly well-bracketed because §j should match 
the outermost opening bracket §o- This contradicts the A-scope condition for §oi. 

To show the Bang condition for v (it is clear for u±, . . . ,u n ), suppose that v con- 
tains a bang subterm v' . We claim that v' does not contain variables x±,...,x n . If it 
contains any, say Xi, then §ot contains v" = t/[§jUj/xj] and the Bang condition for §ot im- 
plies that s(doors(w", §jiij)) > 1. On the other hand, we clearly have s(doors(§oi, v")) > 1 
because v" contains the closing bracket that matches §o- As a consequence, we have 
s(doors(§ot, §iUi)) > 2. This means that §j does not match §o, a contradiction. As a conse- 
quence, v' does not contain x\,... ,x n . So v' occurs in §ot, and therefore satisfies the Bang 
condition. □ 

Now we can prove: 

Theorem 3.6. Let M be a system F term. Then 

X! : Ai, . . . ,x m : A m ; y 1 : Bi, . . . ,y n : B n \~dlal M : C 

if and only if there is a decoration t of M with type C* and with free variables x^ 1 , . . . , x'm m , 
y l 1 , . . . , y n n which is well-structured. 

Proof. The 'only-if ' direction has already been proved. As for the 'if direction, we prove the 

\A* \A* B* 

following: if a pseudo-term t : C* is well-structured and FV(t) = {x l 1 , . . . , x m m , yi 1 , • • • , 
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y n n } for some DLAL types Ai, . . . , A m , B\, ... , B n , then we have T; A \~dlal t~ : C, where 
r = x± : A±, . . . , x m : A m and A = y\ : B±, . . . , y n : B n . The proof proceeds by induction 
on the size of t. 

• When t = x\ % for some 1 < i < m, C* must be §^4* by Local typing, and we have 

B* 

T; A \~dlal xi : §^4j. Likewise, if t = y- 3 for some 1 < j < n, we have T; A \~dlal yj '■ Bj. 

• When t = Xz' A o.u :\Aq — o Cq, u : Cq is also well-structured; observe in particular that 
the Bracketing condition for t implies the same for u. By induction hypothesis, we have 
z : Ao,T; A \~dlal u~ : Co, and hence 

T; A \~dlal \z A » .u~ : A C . 

The case when z has a linear type is similar. 

• When t = Aa.u : Vck.Cq, u : Cq is also well-structured. Hence one can argue as above; 
notice in particular that the eigenvariable condition on t ensures that one can apply the 
rule (V i) to u~ . 

• When t = (u)B* : Cq[B*/o\, u : Vo.Cq is well-structured, and the induction hypothesis 
yields T; A \~dlal u~ '■ Va.Co- We therefore obtain T; A \~dlal ( , u~)B~ : Co[B/a\. 

• It is impossible to have t = §u, because it clearly violates the Bracketing condition. 

• When t = §i' : §Cg, the Boxing Lemma gives us well-structured terms v : Cq, u\ : §C^, 
. . . , Uk ■ §C£ such that 

(1) FV(v) = {z 1 1 , . . . , z k k } and each Zi occurs exactly once in v, 

(2) §t' = §u[§ui/zi,... ,lu k /z k }. 

By the induction hypothesis, we have 

; zi : Ci, . . . , z k : C k h DLAL v~ : Cq and T; Aj \~dlal u~ : §C 

for 1 < i < k, where (Ai, . . . , A k ) is a partition of A such that each Aj contains the free 
variables occurring in U{. Hence by rules (§ i), (§ e) and (Cntr), we obtain 

T; A \~dlal v~[u^/z!,. . .,u~/z k ] : §C . 

• When t = (t')t" and t" is not a bang subterm, one can argue as above. When t" is a bang 
subterm, t' and t" are locally typed as t' :\A* — oC* and t" : §A*. They are well-structured, 
and moreover: 

(i) t" contains at most one free variable x i ' , which is among {xi, . . . , x m }, 

(ii) for any subterm v of t" such that v / t" and v ^ Xj, s(doors(u, v)) > 1. 

By the induction hypothesis on t' (and by the fact that t" does not contain any variable 
of linear type), we have 

r; A \~dlal {tT :A^C. 
On the other hand, the condition (ii) above entails that t" is either the variable Xi or of 
the form §u. In the former case, A* = A* and we have: 

T;Ah {t')- : A^C ; Xi : A\- Xi : A 
r ; A h (t')- Xi : C . 

In the latter case, we can apply the Boxing Lemma. Then the conditions (i) and (ii) 
entail that there is a well-structured term v : A* with a free variable z such that t" = 
§n = §w[§Xj/z]. Notice here that z has a linear type A*, and by renaming, one can assume 
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w.l.o.g. that z = Xi in v. Therefore, we obtain: 

r; A h {t'Y : A => C ; x t : A; h u" : yl 
r; A h (t')-u - : C . 

□ 

As a consequence of Theorem 13.61 our DLAL typing problem (Problem 12. 2|) boils down 

to: 

Problem 3.7 (decoration). Given a system F term M, determine if there exists a decoration 
t of M which is well-structured. 



4. Parameterization and constraints generation 

To solve the decoration problem (Problem 13. 7p . one needs to explore an infinite set 
of decorations. This can be effectively done by introducing an abstract kind of types and 
terms with symbolic parameters (in I4.ip , and expressing the conditions for such abstract 
terms to be materialized by boolean and integer constraints over those parameters (in 14.21 
and in l4l| . 

4.1. Parameterized terms and instantiations. Let us begin with introducing a term 
syntax with parameters. We use two sorts of parameters: integer parameters n, m, . . . 
meant to range over Z, and boolean parameters bi,b2, . . . meant to range over {0, 1}. We 
also use linear combinations of integer parameters c = ni + • • • + n^, where k > and each 
nj is an integer parameter. In case k = 0, it is written as 0. 

The set of parameterized types (p-types for short) is defined by: 

F ::= a \ D -o A \ Ma. A , 

A ::= § C F , 

D ::= § b ' c F . 

where b is a boolean parameter and c is a linear combination of integer parameters. Infor- 
mally speaking, the parameter c in § b ' c i ? stands for the number of modalities ahead of the 
type, while the boolean parameter b serves to determine whether the first modality, if any, 
is § or !. In the sequel, A,B,C stand for linear p-types of the form § C -F, and D for bang 
p-types of the form § b,c i ? , and E for arbitrary p-types. 

When A is a linear p-type § C .F, B[A/a] denotes a p-type obtained by replacing each 
§ c 'a in B with § C '+ C F and each § b - c 'a with § b > c '+ c F. When D = § b ' c F, D° denotes the 
linear p-type § C -F. 

We assume that there is a countable set of variables x D ,y D , ... for each bang p-type 
D. The parameterized pseudo-terms (p-terms for short) t,u . . . are defined by the following 
grammar: 

u ::= x D | \x D .t | (t)t | Aa.t \ (t)A , 
t ::= § m -u. 

We denote by par bool (t) the set of boolean parameters of t, and by par mt (t) the set of 
integer parameters of t. An instantiation <fi = {(fP^ip 1 ) for a p-term t is given by two maps 
4> h : par bool (t) — > {0, 1} and (j) 1 : par mt (t) — > Z. The map <p l can be naturally extended to 
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linear combinations c = ni + • • • + rik by 4> l (c) = </> J (ni) + • • • + l (nk). An instantiation (f> 
is said to be admissible for a p-type E if for any linear combination c occurring in E, we 
have (j) l (c) > 0, and moreover whenever § b,c i 7 occurs in E, (j) b (h) = 1 implies 4> l (c) > 1. 
When 4> is admissible for E, a type 4>(E) of DLAL-k is obtained as follows: 

0(§ C F) = §^( C )0(F), 0(§ b ' c F) = §* i(c V(-F) if</> fe (b) = 0, 

= !§^( c )" 1 </>(i ? ) otherwise, 

and 4> commutes with the other connectives. An instantiation cj) for a p-term t is said to be 
admissible for t if it is admissible for all p-types occurring in t. When c/> is admissible for t, 
a regular pseudo-term cj)(t) can be obtained by replacing each § m, u with §^^ m ^u, each x D 
with x^ D \ and each (t)A with (t)(/>(A). 

As for pseudo-terms there is an erasure map (.)" from p-terms with their p-types to 
system F terms consisting in forgetting modalities and parameters. 

A free linear decoration (free bang decoration, resp.) of a system F type T is a linear 
p-type (bang p-type, resp.) E such that (i) E~ = T, (ii) each linear combination c occurring 
in E is a single integer parameter m, and (hi) the parameters occurring in E are mutually 
distinct. Two free decorations T\ and T2 are said to be disjoint if the set of parameters 
occurring in T% is disjoint from the set of parameters in T2. 

The free decoration M of a system F term M (which is unique up to renaming of 
parameters) is obtained as follows: first, to each variable x T we associate a parameterized 
variable x T = x D in such a way that (i) D is a free bang decoration of T, and (ii) whenever 
x Tl and y T2 are distinct variables, the free bang decorations D\, D2 associated to them are 
disjoint. M is now defined by induction on the construction of M: 

Xx T .M = § m Ax T .M, IWjN = § m ((M)iV), 
Aa7M = § m Aa.M, (M)T = § m ((M)A), 

where all newly introduced parameters m are chosen to be fresh, and the p-type A in 
the definition of (M)T is a free linear decoration of T which is disjoint from all p-types 
appearing in M. 

The key property of free decorations is the following: 

Theorem 4.1. Let M be a system F term and t be a regular pseudo-term. Then t is 
a decoration of M if and only if there is an admissible instantiation <j) for M such that 
4>(M) = t. 

Proof. We first prove that for any system F type T, any free bang decoration D of T and 
any DLAL-k type E, we have E~ = T iff there is an admissible instantiation <ft for D 
such that (f)(D) = E. This statement, as well as a similar one with respect to free linear 
decorations and linear DLAL* types, can be simultaneously proved by induction on T. 
Then the Theorem can be shown by induction on M. □ 

Hence our decoration problem (Problem 13 .7j) boils down to: 

Problem 4.2 (instantiation). Given a system F term M, determine if there exists an 
admissible instantiation <j) for M such that (fi(M) is well-structured. 

For that we will need to be able to state the four conditions (Local typing, Bracketing, 
Bang, and A-scope) on p-terms; they will yield some constraints on parameters. In the 
sequel, we will speak of linear inequations, meaning in fact both linear equations and linear 
inequations. 
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t : § C F : M 

x D : D° : Adm(D) § m i : § m + c F : M U {m + c > 0} 

t : A : M t : § C (D -o B) : Mi u : A : M 2 



Xx D .t : §°(L> -o A) : M U Adm(D) (t)u : 5 : Mi U M 2 U {c = 0} U U(D°,A) 

t : A: M * : § C (V«-^) ■ Aj 

Aa.t : §°Va.A : M (t)A : B[A/a] : M U {c = 0} U Adm(A) 

Figure 6: Local typing and M(t) constraints. 



4.2. Local typing constraints. First of all, we need to express the unifiability of two 
p-types Ei and E 2 . We define a set U{E\, E 2 ) of constraints by 

U(a,a) = 0, 

U(Di^A u D 2 ^>A 2 ) = U(Di,D 2 )UU(Ai,A 2 ), 

W(Va.Ai,Va.A 2 ) = U{A X ,A 2 ), 

^(§ Cl Fi,§ C2 F 2 ) = {ci = C2}UW(Fi, J P 2 ), 

W ( § b 1 ,c 1Fi>§ b a ,c a _p 2) = {bi =b2)Cl =c 2 }UW(Fi,F 2 ). 

It is undefined otherwise. It is straightforward to observe: 

Lemma 4.3. Let E\, E 2 be two linear (bang, resp.) p-types such that E± = E^ ■ Then 
U(Ei,E 2 ) is defined. Moreover, when 4> is an admissible instantiation for E\ and E 2 , we 
have <p{E\) = 4>(E 2 ) if and only if (j) is a solution ofl{(Ei,E 2 ). 

Proof. By induction on E±. □ 
For any p-type E, define 

Adm(E) = {c > : c occurs in E} U {b = 1 =>■ c > 1 : § b ' c F occurs in E}. 

Then <p is admissible for E if and only if is a solution of Adm(i^). 

Now consider the free decoration M of a system F typed term M. We assign to each 
subterm t of M a linear p-type B and a set M of constraints (indicated as t : B : M) as on 
Figure [6l Notice that any linear p-type is of the form § C -F. Moreover, since t comes from a 
system F typed term, we know that t has a p-type § C (-D — o B) when t occurs as (t)u, and 
§ c (Va.-B) when t occurs as (t)A. In the former case, we have (D°)~ = A~ , so that U(D°,A) 
used in the application rule is always defined. As a consequence, for any M a unique p-type 
and a unique set of constraints M(M) are obtained. Finally, observe that M satisfies the 
eigenvariable condition. 

Let Ltype(M) be M(M) U {b = 1 : x§ ' CF occurs more than once in M}. 

Lemma 4.4. Let M be a system F term and (j) be an instantiation for M . Then (p is 
admissible for M and <p{M) satisfies the Local typing condition if and only if (j) is a solution 
of Ltype(TT). 
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4.3. Boxing constraints. We consider the words over integer parameters m, n . . . , whose 
set we denote by C p . Let £ be a p-term and u an occurrence of subterm of £. We define, 
as for pseudo-terms, the word doors(£, u) in £ p as follows. If £ = u, let doors(£, it) = e. 
Otherwise: 

doors(§ m £, u) = m :: (doors(£, «)), 

doors(Ay D .ti, u) = doors(Aa.£i, u) = doors((£i)j4, u) = doors(£i, u), 
doors((£i)£2, it) = doors(ij,w) where £j is the subterm containing u. 

The sum s(l) of an element I of C p is a linear combination of integer parameters defined by: 

s(e) = 0, s(m :: I) = m + s(l). 

For each list I G £ p , define wbracket(7) = {s(V) > | V < 1} and bracket(7) = wbracket(Z) U 
{s(l) = 0}. 

Given a system F term M, we consider the following sets of constraints: 

Bracketing constraints. Bracket(M) is the union of the following sets: 

(i) for each occurrence of free variable x in M, bracket(doors(M, x)); 

(ii) for each occurrence of an abstraction subterm Xx.v of M: 
(ii.a) wbracket(doors(M, Xx.v)), 

(ii.b) for any occurrence of x in v, bracket(doors(w, x)). 

Bang constraints. A subterm u that occurs in M as (t)u with t : § c '(§ b ' c i ? — ° B) is 
called a bang subterm of M with the critical parameter b. Now Bang(Af) is the union of 
the following sets: for each bang subterm u of M with a critical parameter b, 

(i) {b = 0} if u has strictly more than one occurrence of free variable, and 

{b = 1 b' = 1} if u has exactly one occurrence of free variable x§ ,c F . 

(ii) {b = 1 s(doors( , u, v)) > 1 : v subterm of u such that v ^ u and v ^ x}U 

{b = 1 ^> s(doors(u, x)) = 0}. 

(where x is the free occurrence of variable in u, if there is one, otherwise the second 
set in the union is removed) 

Remark 4.5. Note that if £ is a p-term and 4> is an instantiation, the pseudo-term <f>(t) 
might have more subterms than t. In fact subterms of the p-term t are in correspondence 
with door-extreme subterms of the regular pseudo-term </>(£). 

For instance if t = § m x and <p(m) = 2, the subterms of £ and </>(£) are respectively 
{§ m x,j;} and {§ 2 x,§x,x}. The door-extreme subterms of <f>(t) are {§ 2 x,x}. 

This is why we had to add in the Bang constraints (ii) the condition {b = 1 => 
s(doors(u, x)) = 0} (see Lemma [373]) . 

A-Scope constraints. Scope(M) is the union of the following sets: 
(i) wbracket(doors(ii, v)) for each subterm Aa.u of M and for each subterm v of u that 
depends on a. 

We denote Const(M) = Ltype(M) U Bracket(M) U Bang(M) U Scope(M). 

Remark 4.6. Instead of using p-terms, the parameters and constraints might be visualized 
on pseudo-terms graphs. Using our running example of Fig. [5] we can decorate it with 
parameters mj: see Fig. [71 Each mi stands for a possible sequence of doors: if it is 
instantiated with k > (resp. k < —1) then this will correspond to k (resp. (— k)) 
opening (resp. closing) doors. Then, for instance, the Bracketing constraints correspond to 
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conditions on the parameters occurring along certain paths of the graph (as indicated in 
Remark 13. ip . As an example the Bracketing constraint (ii.b) for the binder A/ and the two 
free occurrences of / gives here {rri3 > 0, m3 + m4 = 0, m3 + m5 > 0, m3 + m5 + m6 = 0}. 



mi 




Figure 7: Example of parameterized pseudo-term graph. 

Theorem 4.7. Let M be a system F term and (ft be an instantiation for M . Then: (ft is 
admissible for M and <ft{M) is well- structured if and only if (ft is a solution of Const(-M). 
Moreover, the number of (in)equations in Const(M) is quadratic in the size of M. 

Proof. Clearly, the above constraints are almost direct parameterizations of the correspond- 
ing conditions given in the previous section. Let us just examine the Bang condition. 

Suppose that 4>(M) satisfies the Bang condition. For each (parameterized) bang sub- 
term u with the critical parameter b in M, one of the following two happens: 

• 4>(u) is not a bang subterm of (ft(M) (in the sense of the previous section). Namely, 
4>(h) = 0. In this case, (ft is a solution of the equation b = 0, and also of b = 1 b' = 1 

if u has a free variable x^ c F . 

• (f>(u) is a bang subterm of cft(M). Namely, 0(b) = 1. In this case, u contains at most one 
variable by the Bang condition. Hence the equation b = does not belong to Bang(M). 

Moreover, if u has a free variable x§ b c F ', 4>(x) must have a bang type and so 0(b') = 1. 
Hence eft is a solution of b = 1 => b' = 1. 

It is straightforward to observe that is a solution of the equations in (ii) , by using Lemma 
13.31 Therefore, ^ is a solution of Bang(M). 

Now suppose the converse and let u be a (parameterized) bang subterm with the critical 
parameter b in M. Suppose also that 4>(u) is a bang subterm of <fi(M). This means that 
0(b) = 1. Since (ft is supposed to be a solution of Bang(M), u must contain at most one free 

variable, say x§ b ' c F ' . Moreover, we have <ft(h') = 1, which means that <ft(x) has a bang type 
in (ft(M). Therefore, 4>{M) satisfies the Bang condition (i). As (ft satisfies the conditions 
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in (ii) and <f>(h) = 1 we get that (f>(u) satisfies the condition in Lemma 13,31 hence by this 
Lemma we obtain that <f>(u) satisfies the Bang condition (ii). □ 

5. Solving the constraints 

Having described a way to collect a set of constraints from a given system F term, there 
just remains to give a fast algorithm to solve them. Our method proceeds as follows: first 
solve the boolean constraints, which corresponds to determine which !-boxes are necessary 
(in !5.ip . and then solve the integer constraints, which corresponds to complete the decoration 
by finding a suitable box structure (in 15.21) . 

5.1. Solving boolean constraints. We split Const(M) into three disjoint sets Const fe (M), 
Const l (M), Const m (M): 

• A boolean constraint s E Const 6 (M) consists of only boolean parameters, s is of one of 
the following forms: 

bi = b 2 (in Ltype(M)), b = 1 (in Ltype(M)), 

b = (in Bang(M)), b = 1 b' = 1 (in Bang(M)). 

• A linear constraint s E Const* (M) deals with integer parameters only. A linear constraint 
s is of one of the following forms: 

ci = c 2 (in Ltype(M)), 

c > (in Ltype(M), Bracket(M), Scope(M)), 
c = (in Ltype(M) and Bracket(M)). 

• A mixed constraint s E Const™ (M) contains a boolean parameter and a linear combina- 
tion and is of the following form: 

b = 1 => c = (in Bang(M)), 

b = 1 => c > 1 (in Ltype(M) and Bang(M)). 

We first try to find a solution of Const b (M), and then proceed to the other constraints. 
This does not cause loss of generality, because Const 6 (M) admits a minimal solution when- 
ever solvable. Let us consider the set of instantiations on boolean parameters and the 
extensional order < on these maps: tfr < (j) b if for any b, ip b (h) < 4> b (h). 

Lemma 5.1. There is a polynomial time algorithm to decide whether Const 6 (M) has a 
solution or not. Moreover, the algorithm returns a minimal solution whenever there exists 
any. 

Proof. Our algorithm is based on the standard resolution procedure. Let B := Const b (M). 
Apply repeatedly the following steps until reaching a fixpoint: 

• if bi = b 2 E B and bi = i E B with i E {0, 1}, then let B := B U {b 2 = i}; 

• if bi = b 2 E B and b 2 = i E B with i E {0, 1}, then let B := B U {bi = i}; 

• if (b = 1 => b' = 1) E B and b = 1 E B, then let B:=BU{h' = 1}. 
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It is obvious that this can be done in a linear number of steps and that the resulting system 
B is equivalent to Const h (M). 

Now, if B contains a pair of equations: b = 0,b = 1, then it is inconsistent, and hence 
Const b (M) does not have a solution. Otherwise, define the boolean instantiation ip b by 

iP b (b) := 1 ifb = le£; 
:= otherwise. 

It is clear that ifi is a solution of B. In particular, observe that any constraint of the form 
(b = 1 => b' = 1) in B is satisfied by t/j b . Moreover any solution <p b of B satisfies ip b < 4> b . 
Therefore, ip b is a minimal solution of Const b (M). □ 

5.2. Solving integer constraints. When 4> b is a boolean instantiation, 4> b 'Const™ (M) de- 
notes the set of linear constraints defined as follows: 

• for any constraint of the form (b = 1 X) in Const m (M), where X is a linear (in)equation 

(of the form c > 1 or c = 0), X belongs to 4> b 'Const™ - (M) if and only if 4> b (h) = 1. 
Then we clearly have: 

(*) (<j) b , 4> % ) is a solution of Const(M) if and only if 4> b is a solution of Const 6 (M) and <p l is 
a solution of c/> 6 Const m (M) U Consf(M). 

Lemma 5.2. Const(Af) admits a solution if and only if it has a solution tp = (ip b ,tp % ) such 
that ip b is the minimal solution of Const 6 (M). 

Proof. Suppose that Const(Af) admits a solution Then by the previous Lemma, 

there is a minimal solution -0 b of Const fe (M). Since i) b < (j) b , we have -0 6 Const m (M) c 
/Const™ (M). Since ft is a solution of (f) b Const m (M) U Const* (M) by (*) above, it is also a 
solution of V 6 Const m (M)u Const* (M). This means that cf/) is a solution of Const(Af ). I I 

Coming back to the proof-net intuition, Lemma 15.21 means that given a syntactic tree 
of term there is a most general (minimal) way to place !-boxes (and accordingly ! subtypes 
in types), that is to say: if there is a DLAL decoration for this tree then there is one with 
precisely this minimal distribution of !-boxes. 

Now notice that V fe Const m (M) U Const'(M) is a linear inequation system, for which a 
polynomial time procedure for searching a rational solution is known QKac79, Kar84j). 

Lemma 5.3. ^ 6 Const m (A/) U Const l (M) has a solution in Q if and only if it has a solution 
in Z. 

Proof. Clearly the set of solutions is closed under multiplication by a positive integer. □ 

Theorem 5.4. Let M be a system F term. Then one can decide in time polynomial in the 
cardinality o/Const(M) whether Const(M) admits a solution. 

Proof. First decide if there is a solution of Const fe (M), and if it exists, let ip b be the minimal 
one (Lemma I5.ip . Then apply the polynomial time procedure to decide if ip b Const" 1 (M) U 
Const* (M) admits a solution in Q. If it does, then we also have an integer solution (Lemma 
15. 3p . Otherwise, Const (M) is not solvable. □ 
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By combining Theorems 13,61 14,11 14,71 and 15.41 we conclude that the DLAL typing 
problem (Problem 12. 2\) can be solved in polynomial time: 

Theorem 5.5. Given a system F term M T , it is decidable in time polynomial in the size 
of M whether there is a decoration AofT such that \~dlal M : A. 

6. Data-types and typing with domain specification 

6.1. Data- types. Now that we have a type inference procedure, we can reexamine the 
data-types in system F and the corresponding types in DLAL. 
Consider for instance the system F type for unary integers: 

Np = Va.(a — > a) — > (a — > a) . 

We denote by k the Church integer for k. 

If we apply the type inference procedure to the Church integer 2, we obtain the following 
family of parameterized types with constraints as result: 

' A = § ni Va.§ n2 [§ b3 ' n3 (§ b4 > n4 a -o § n5 a) -o § n6 (§ b7 < n7 a -o § n «a)] 
bs = 1, b 4 = b7 = 
n 4 = n 5 , n 7 = n 8 , 
n3 + n 4 = n 6 + n 7 

n 7 > n 4 

n; > 0, rij > bj for 1 < i < 8 and j = 3. 

It is easy to check that conversely, any solution to this system gives a type suitable 
for all Church integers. We denote by M{A) this set of constraints. If D is a free bang 
decoration of N F , we define M{D) = M{D°). 

Observe that the type Njjlal = Va.(a — o a) => §(q — o q) is obtained by a solution of 
this system (0(113) = <P(p-e) = 1 ; 0( n i) = for i 7^ 3, 6, (j)(bs) = 1, 0(b 4 ) = (f>(hr) = 0) but 
it is not the only one. For instance the following types are also suitable DLAL types for 
Church integers: 

• ^'dlal = ^ a -( a —° a ) (§ a —° § Q )> 

obtained with 0o defined as the previous (j), but for 0o( n 6) = 0, (po(nr) = 4>o(ns) = 1. 

• §Va.§ 2 (§a — o §a) §(§ 3 a ^> § 3 a), 

obtained with 0i(ni) = 1 for i = 1,4,5,6; 0i(ni) = 3 for i = 3,7,8; ^1(112) = 0, 
0i (b 3 ) = 1, 0i (b 4 ) = 0i(b 7 ) = 0. 
In the same way we can characterise the DLAL types for the Church representations 
of binary words, with a linear free decoration A of the system F type Wp and the following 
set of constraints W(A). 

' A = § ni Va.§ n2 [§ b3 ' n3 (§ b4 ' n4 a -o § n5 a) -o § ne [§ b ^ n ^(§ b ^ n 8 a -<, § n " a ) -o §"io(§bxi,n llQ _^ gn 12Q , 

b 3 = b 7 = 1, b 4 = b 8 = bn = 
n 4 = n 5 , n 8 = n 9 , n n = n 12 , 
n 3 + n 4 = n 6 + n 7 + n 8 , 
n 7 + n 8 = nio + nn, 
nn > n 8 
nn > n 4 

n ; > 0, nj > bj for 1 < i < 12 and j = 3, 7. 
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6.2. Typing with domain specification. Actually the DLAL typability of a term 
M Wf ~* Wf of system F is not sufficient to ensure that M is Ptime computable. To il- 
lustrate this point, we consider for simplicity unary Church integers and terms of type 
Np — > Np. Observe that the following term of system F has type Np —> Np and represents 
the exponentiation function (2 n ) over unary integers: 

exp = An. A/3. (n 0^(3)(2f3). 

Thus the term exp does not represent a Ptime function but. . . it is typable in DLAL, with 
for instance the type: 

Va.[(a §a) - (a §a)] - V/3.[(/3 - /?) => §(/3 - /3)]. 

The trick here is that this DLAL type does not allow the term exp to be applied to all 
Church integers. Indeed the only closed terms of type Va.[(a §a) — ° (a => §a)] are 
and 1. So we do obtain a Ptime term but over a restricted, finite domain. . . 

In general we are therefore not just interested in mere typability but in typability with 
meaningful types. Indeed we generally want the terms to be typable in DLAL in such a 
way that they can be applied to arguments of certain data-types (unary integers, lists. . . ). 
This can be enforced by adding some specification about the domain of the function. 

Let M be a system F term of type T. We call a domain specification of M a list 
Dom = ((x\, si), . . . , (xfc, Sfe)) such that for each i: 

• x% is a bound variable of M, 
. Si € {N,W}, 

• if Si = N (resp. Sj = W), then Xi is of type Np (resp. Wf) in M. 

For instance for the previous example of term exp we can take Dom = {(n, N)}. 

Here we restrict to Nf, Wf for simplicity, but this definition could be extended to other 
data-types of system F such as lists, binary trees. . . 

Now we consider the free decoration M. Let Dom Const (M, Dom) be the union oiJ\f{Di) 
(resp. W(Di)) for all bound variables x i 1 such that (xj,N) (resp. (xj, W)) is in Dom. 

Finding a DLAL type for M such that, in the resulting DLAL typed term, each Xi 
from Dom can be instantiated with a Church integer or binary word, is thus equivalent to 
finding a solution of Const(M) which also satisfies DomConst(M, Dom). In the previous 
example of exp and the domain specification Dom, there is not any such solution. 

We have: 

Theorem 6.1. Let M be a System F term and Dom be a domain specification. One can 
decide in time polynomial in the cardinality of Const(M) U DomConst(M, Dom) whether it 
admits a solution. 

Proof. It is sufficient to observe that the constraints in M{D) (where D is a decoration of 
Np or Wf) also satisfy the properties used to prove Lemma 15-H Lemma 15.21 and Lemma 

Note that for Lemma 15.31 for instance the argument would not be valid anymore (at 
least in an obvious way) if we added constraints of the form n = 1 or n < 1. □ 
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Therefore one can perform DLAL decoration for system F terms in polynomial time 
even with domain specification. 

7. IMPLEMENTATION AND EXAMPLES 

7.1. Overview. We designed an implementation of the type inference algorithm. The 
program is written in functional CAML and is quite concise (less than 1500 lines). A 
running program not only shows the actual feasibility of our method, but is also a great 
facility for building examples, and thus might allow for a finer study of the algorithm. 

Data types as well as functions closely follow the previous description of the algorithm: 
writing the program in such a way tends to minimise the number of bugs, and speaks up 
for the robustness of the whole proof development. 

The program consists of several successive parts: 

(1) Parsing phase: turns the input text into a concrete syntax tree. The input is a system F 
typing judgement, in a Church style syntax with type annotations at the binders. It is 
changed into the de Bruijn notation, and parameterized with fresh parameters. Finally, 
the abstract tree is decorated with parameterized types at each node. 

(2) Constraints generation: performs explorations on the tree and generates the boolean, 
linear and mixed constraints. 

(3) Boolean constraints resolution: gives the minimal solution of the boolean constraints, 
or answers negatively if the set admits no solution. 

(4) Constraints printing: builds the final set of linear constraints. 

We use a solver employing the simplex algorithm to solve the linear constraints. It runs 
in time 0(2"), which comes in contrast with the previous result of polynomial time solving, 
but has proven to be the best in practice. 

We now have to define the objective function that we will give to the solver. Basically, 
to minimize the resulting complexity bound, we should have an objective function which 
minimizes the nesting depth of the boxes of the typed term. To achieve this, we would 
have to minimize the maximum of the sums of door parameters from the root to each node 
(this corresponds to the depth of the proof-net, which yields the bound of Theorem 12. ID , 
This clearly calls for a minimax objective function. Unfortunately, this does not fit into the 
linear programming setting that we are currently using: our objective function can only be 
a ponderated sum of variables. 

So, we chose to simply put as objective function the sum of door parameters. A little 
trick is needed in order to handle the case of variables which are not of positive domain, 
and could lead to the absence of an optimal solution. Once this special case is handled, the 
solver always gives sensible results in practice. 

The program, together with some examples, is available at: 

http : //www-lipn.univ-paris l3 . f r/~atassi71 



7.2. Two examples: reversing of list and predecessor. 
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7.2.1. List reversing. Let us consider the reversing function on binary words. It can be de- 
fined by a single higher-order iteration on the type Wf, with the untyped term 
Xw.Xso.Xsi.(w) stepo stepi base, with : 

• base term: base = Xz.z, 

• step terms: stepo = Xa.Xx.(a)(so)x, step± = Xa.Xx.(a)(si)x. 
We obtain as system F term the following one, denoted rev: 

Xl w Ap.Xso^.Xsi^.il (/3 p)) 
\ a P-+p .Xx" .(a)(so)x 
Xofl-*P .Xx? .(a){si)x Xz^.z . 

As discussed in Section 16.21 to obtain a meaningful typing we need to force the domain 
of the term to be that of binary words. For that a simple way is to apply the term to a 
particular argument, for instance: Aa.Xso a ^ a .Xsi a ^ a .Xx a .(si)(so)(si)(so)x, representing 
the word 1010 . Since rev involves higher-order functionals and polymorphism, it is not so 
straightforward to tell, just by looking at the term structure, whether it works in polynomial 
time or not. 

Given rev (1010) as input (coded by ASCII characters), our program produces 200 
(in)equations on 76 variables. After constraint solving, we obtain the result: 

{Xl w A§.Xso^-^\XsiW^\ 

§G((« (0^0) 

§Xa^P.XxP.(a)(po)x 
§XaP-°P.XxP.ia)(§si)x) 
XzP.z) 

Aa.Xso- a ^ a .Xsi a ^ a .§Xx a .(§si)(§so)(§si){§so) .x . 

It corresponds to the natural depth-1 typing of the term rev, with conclusion type Wdlal —° 
Wdlal- The solution ensures polynomial time termination, and in fact its depth guarantees 
normalization in a quadratic number of /3-reduction steps. 

7.2.2. Predecessor on unary integers. We now turn to another example which illustrates 
the use of polymorphism: the predecessor function on unary integers. 

We consider a slight simplification of the term given by Asperti (|Asp98|). The simpli- 
fication is not needed for typability, but is just chosen to facilitate readability. 
For that we consider: 

• pairs represented in the following way: < P,Q > : Xz.(z) P Q, 

• terms for projection and an application combinator for pairs: 

fst = Xx.Xy.x, 
snd = Xx.Xy.y, 
appl = Xx.Xy.(x)y . 

We will do an iteration on type Np, with: 

• base term: < I, x > (where I = Xx.x), 

• step term: Xp. < f, (p) appl >. 

The untyped term will then be An.((n) step base) snd. 
Let us specify the system F typing of the subterms: 

• <P,Q>= Xz^^^.(z) QP : ((/? -»• p) -»■ (J3 -> P)) -» p, 
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. step = \p((W)^(f3->m->P.\z(P-+P)^(W).( z ) fW(p)appl^^^® : 

(((/? -> p) - 09 -> /?)) -/?)-» (((/? -» /?) -> 03 - /?)) - /?), 
. base = A^-^(^).(z) 1^ x : ((/? /9) -» (/3 -> /?)) -> /3 . 
The overall F-typed term for predecessor, denoted pred is thus: 

An Va.(a^a)-,( Q ~,a)_ A/3 _ A ^/3_ Ax /3_ 
( 

(n ((/3 -» 0) -> (/J - /?)) - /?) 

Ap ((/3-/3)-(/3-/3))-/3. Az (/3-/3)-(^/3). (z) ^ (p) oflp |(0-0-(/^) 

XzW-*®^-*®.^) Xa^.ax) 

) 

Observe that this term is linear (as Asperti's original one). Again, to force a meaningful 
typing we apply the term pred to a Church integer argument, here the integer 2. 

The program then produces 220 equations, for 130 parameters. The solver produces a 
solution, yielding the following type for the subterm pred: 

(Va.(a — o a) => §(a ^> a)) — ° (Vat. (a — ° a) =>■ §(a — ° a)), 

which corresponds to the Njjlal —° ^dlal type. 

7.3. Experiments with larger examples: polynomials. In order to test our type infer- 
ence program with larger examples it is interesting to consider a family of system F terms of 
increasing size. The family of terms representing polynomial functions over unary integers 
is a natural candidate for this goal, since in particular it is important for the encoding of 
polynomial time Turing machines in the system ( [AR02^ IBT04j ). 

Therefore we wrote a CAML program which given a polynomial P outputs a system 
F term representing P and with type Np — > Np, that can then be fed to the DLAL type 
inference program. 

There is however a subtlety that needs to be stressed. Recall that in order to represent 
polynomial functions in LAL or DLAL with suitable types it is necessary to use type 
coercions (AR02, BT04]). These coercions are needed just for typing reasons, and not 
for computational ones. However, if we consider the system F terms underlying the LAL 
or DLAL terms for polynomials the coercions are still present and correspond to explicit 
subterms. 

So if we want our system F terms representing polynomials to be typable in DLAL we 
need to anticipate on the need for coercions. Therefore our program generating system F 
terms for polynomials is guided by the encoding of polynomials in DLAL, in particular it 
takes into account the placement of subterms for coercions (even if the terms are not yet 
typed with modalities during this phase). It should be stressed that this increases con- 
siderably the size of the resulting term: in practice inside the resulting term the subpart 
accounting for the management of coercions is larger than the subpart performing a compu- 
tational task. . . This makes however a good test for our type inference program, since the 
typing is not trivial and will put into use a large number of parameters and constraints. 

In the following we will: 
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• describe the encoding of polynomials used, 

• report on experiments of our type inference program on terms of this family. 

Encoding of polynomials. 

We recall from [BT04] the rules for coercions on type Ndlal derivable in DLAL: 

n: N DLAL ;Aht: A 

T;n: %N DLAL ,A^t : A 
T;m:N DLAL ,A^C 2 [t]:A ^ oerc ^ 
where C\[.} and C2[.] are contexts, which contain as free variables some variables of the 
environments: 

C\[x] = (m(Xg.Xp.(g (succ p))))(Xn.x)Q, 
C 2 [x\ = (Xn.x)(m succ 0) . 

Here succ is the usual term for successor. 

Similarly we define the term coerc = Xn.(n) succ 0, which can be given in DLAL any 
type N DLAL -0 % k N DLAL with k > 0. 

Multiplication can be represented by the (untyped) term mult = Xn.Xm.u with u = 
((m) Xk.Xf.Xx.(n) f (k) f x) 0. It can be given in DLAL the type Ndlal => Ndlal — 
§Ndlal- 

Now, in order to give multiplication any type: § k Ndlal —° § k Ndlal — ° § fc+2 Ndlal 
with k > we can use coercions: 



n : N DLAL ;m : N DLAL h u : §Ndlal 

I Of^TT 1 — I 

]n 2 : N DLAL ,m : Wdlal ^ Ci[u] : % 2 N DLAL 

C>ocrc _ ^ 

m ,n 2 : N DLAL ,m 2 : N DLAL h C 2 [Ci[it]] : % 2 N DLAL 

Q— 1 X rC 

; n 2 : § k N DLA L, m 2 : % k N DLAL h C 2 [d[«]] : § fe + 2 A^ LA L 
Note that there is here a small abuse of notation as now the free variable of C\[.} is 

called n 2 (similarly for C 2 [.]). 

We will associate to each polynomial P of N[X] a system F term tp of type Np — > Np 

representing it, and which is typable in DLAL. We first describe the encoding of monomials. 
We define the term tx n by induction on n: 

t x o = Xx.l , t x i = Xx.x , t X "+i = Xx.Ci[(Xn 2 .Xm 2 .C 2 [Ci[u]]) [tx n ) x {coerc) x], 
for n > 1. 

The term tx n can be given in DLAL the type Ndlal —° ^ n Ndlal- Actually a better 
encoding of monomials could be given, with a lower depth, but we stick here to this one for 
simplicity. To show that txn can be typed with Ndlal —° § 4n Ndlal note that it is easy 
to observe for tj^o and t x t , and supposing it for tx n we get for t x «+i (N in this derivation 
stands for Ndlal)'- 



VERIFICATION OF PTIME REDUCIBILITY FOR SYSTEM F TERMS: TYPE INFERENCE IN DLAL 29 



— § i x 4n 

h An 2 .Am 2 .C 2 [CiM] : § 4 "7V -o § 4 "Af -o § 4n+2 Ar ' \x\ : )V h (tx n ) x i '■ % 4n N 

;ii : N h (An 2 .Am 2 .C 2 [Ci[ti]]) (t x ») H : § 4 "AT -° § 4 ™ +2 iV ; x 2 : N h (coerc) a; 2 : § 4 "7V 

;il : JV,a; 2 : N h (An 2 .Am 2 .C 2 [Ci[«]]) (t x ») Xi (coerc) x 2 : § 4 "+ 2 AT 

§i 

H : N, X2 : N;h ( An 2 . Am 2 .C 2 [Ci [«]]) (t X ») xi (coerc) x 2 : § 4 '*+ 3 AT 

contr 

x : JV; h ((An 2 .Am 2 .C 2 [Ci[«]]) (t x n) a; (coerc) x ■ § 4ll+3 AT 
i coerc - 1 

;x : N h Ci[(An 2 .Am 2 .C 2 [CiM]) (t X n) x (coerc) x] : § 4 "+ 4 AT 

h Aa;.Ci[(An 2 .Am 2 .C 2 [CiM]) (t x « ) x (coerc) x] : N -o § 4 <™ + 1 )Ar 

Now, once tjf" has been defined it is easy to represent monomials with coefficient, a n X n 

j 

and, using the term for addition and coercions again, arbitrary polynomials: a niX n '. 

i=l 

Experiments of type inference. 

We wrote a small program implementing this encoding, which, given a polynomial, 
produces a system F term representing it. Then we used it to test our DLAL type inference 
program. We give the results of the experiments on a few examples, in the array of Figure 
[SI where tp denotes the F term representing a polynomial. Again we stress that the large 
size of tp, even for small polynomials, is due to the coercions (for instance the encoding of 
x 5 without coercions produces a term of size 322 — which is not typable however) and to 
the fact that all types are written explicitly in the term, since it is written in a la Church 
style syntax. 

In the array the following quantities are reported: 

• the size of tp is the number of symbols of the term; 

• the column # Par stands for the number of parameters in the resulting parameterized 
term, 

• the time (in seconds) for generating the set of linear constraints is divided in two parts: 

• GEN is the time taken by the program for parsing the input, generating the whole 
constraints and solving the boolean part, 

• SIMPL is the time taken to simplify the set of constraints (this is a preprocessing 
before using the solver). 

• Cons is the cardinality of the set of of linear constraints generated by the program, 

• Sol is the time taken by the solver (LPsol) to solve the set of constraints. 

Recall that N' DLAL = Va.(a — ° a) §a — o §a. We think that the fact that we 
obtain a N' DLAL type instead of Nqlal on the right-hand-side is not significative here: 
we could force obtention of a No lal type instead by techniques similar to that of domain 
specification of Section [6] (adding a constraint of the form p = 0). 

Note that the type obtained is slightly smaller (containing fewer § and of smaller depth) 
than the one described above: we obtain the type Ndlal —° § 4n_s 'N' DLAL for tx n , and it 
is possible to check that this is indeed a suitable type in general. 

Observe that on these examples the respective times needed for generating the con- 
straints and solving the boolean part (GEN) on the one hand, and for simplifying the 
linear constraints (SIMPL) on the other, are comparable. The time needed to solve the 
linear constraints (Sol) is comparatively smaller. 

We also generated the system F terms representing the same polynomials but without 
subterms for coercions, and noted with our program that type inference in DLAL for these 
terms fails: coercions are indeed necessary. 
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In the array N (resp. N') stands for Ndlal (resp. N' DLAL ). 



Figure 8: Type inference for terms representing polynomials. 

Even though the family of terms tx n is a particular case, these examples illustrate 
the fact that our algorithm is manageable with lambda-terms of reasonable size, and gives 
results in a sensible time. 

8. Discussion and further work for the case of propositional DLAL 

It should be stressed that our method can be applied to type untyped lambda-terms in 
propositional (quantifier-free) DLAL. Indeed, propositional DLAL can naturally be seen 
as a subsystem of DLAL. Given an untyped term t, we can thus proceed in the following 
way (in the lines of previous works for EAL or LAL like [CMO!} rBai02| ): 

(1) search for the principal simple type of t, 

(2) using the principal simple type derivation of t, search for a valid DLAL decoration 
by using our method. 

If we find a suitable decoration then it will give a derivation in propositional DLAL (simply 
because the underlying system F derivation does not use quantification). It can be checked 
that this method is complete (for instance by a simple adaptation of the argument in 
[Bai04]): if the term is typable in propositional DLAL, then a suitable decoration of the 
principal simple type decoration will be found. 

However, the bound on this procedure given by Theorem 15.51 is polynomial w.r.t. the 
size of the principal simple type derivation oft, and not w.r.t. to the size \t\ of the untyped 
term t itself. 

Still, we strongly believe that our method can be adapted in order to give an algorithm 
performing type inference in propositional DLAL for an untyped term t in time polynomial 
in \t\. 

The starting point is that it is known that simple type inference can be done in polyno- 
mial time by using a shared representation of types. If one designs an algorithm performing 
together simple type inference and decoration with parameters, one can presumably obtain, 
instead of a free decoration of t, a suitable decoration with a number of parameters poly- 
nomial in |t| (by taking advantage of the shared representation of types) and a constraints 
system also polynomial in \t\. Hence in the end type inference would be polynomial w.r.t. 
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\t\. We also believe that in this way we would obtain a notion of principal propositional 
DLAL type. This would be analogous to the work of [CRdR03] for EAL, but could give a 
single principal type scheme instead of a finite family of principal type schemes. 

However in the present paper we preferred to follow the approach starting with a system 
F typed term in order to be able to consider second-order DLAL typing, which is more 
interesting for expressivity reasons (propositional DLAL is not complete for polynomial 
time computation). The case of polynomial time type inference for propositional DLAL is 
left for future work. 

9. Conclusion 

We showed that typing of system F terms in DLAL can be performed in a feasible way, 
by reducing typability to a constraints solving problem and designing a resolution algorithm. 
This demonstrates a practical advantage of DLAL over LAL, while keeping the other 
important properties. We illustrated the manageability of our algorithm by implementing 
it in CAML and giving some examples of type inference. Note that other typing features 
could still be automatically inferred, like coercions (see [Ata05| for the case of EAL). 

This work illustrates how Linear logic proof-net notions like boxes can give rise to 
techniques effectively usable in type inference, even with the strong boxing discipline of 
DLAL, which extends previous work on EAL. We expect that some of these techniques 
could be adapted to other variants of Linear logic, existing (like Soft linear logic) or to be 
defined in the future. 
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